<!DOCTYPE html>
<html lang="zh-cn">
<head>
  <meta charset="utf-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
  <title>更改 Docker 数据的存储目录 - jouyouyun&#39;s blog</title>
  <meta name="renderer" content="webkit" />
<meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1"/>

<meta http-equiv="Cache-Control" content="no-transform" />
<meta http-equiv="Cache-Control" content="no-siteapp" />

<meta name="theme-color" content="#f8f5ec" />
<meta name="msapplication-navbutton-color" content="#f8f5ec">
<meta name="apple-mobile-web-app-capable" content="yes">
<meta name="apple-mobile-web-app-status-bar-style" content="#f8f5ec">


<meta name="author" content="jouyouyun" /><meta name="description" content="Docker 安装后默认将数据存储在 /var/lib/docker 下，随着 image 和 container 的增多，会导致 / 分区的空间被用完，如果 / 分区特别大就请忽略这篇文章。
因此需要将一些软件的数据存储到空间大的分区，与 / 分区分开。不仅 Docker 需要这样处理，如 mysql/postgresql 等软件也需要这样处理。
" /><meta name="keywords" content="jouyouyun, Hugo, theme, even" />






<meta name="generator" content="Hugo 0.54.0 with even 4.0.0" />


<link rel="canonical" href="https://jouyouyun.github.io/post/docker-image-storage/" />
<link rel="apple-touch-icon" sizes="180x180" href="/apple-touch-icon.png">
<link rel="icon" type="image/png" sizes="32x32" href="/favicon-32x32.png">
<link rel="icon" type="image/png" sizes="16x16" href="/favicon-16x16.png">
<link rel="manifest" href="/manifest.json">
<link rel="mask-icon" href="/safari-pinned-tab.svg" color="#5bbad5">


<link href="/dist/even.93844dae.min.css" rel="stylesheet">
<link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/@fancyapps/fancybox@3.1.20/dist/jquery.fancybox.min.css" integrity="sha256-7TyXnr2YU040zfSP+rEcz29ggW4j56/ujTPwjMzyqFY=" crossorigin="anonymous">


<meta property="og:title" content="更改 Docker 数据的存储目录" />
<meta property="og:description" content="Docker 安装后默认将数据存储在 /var/lib/docker 下，随着 image 和 container 的增多，会导致 / 分区的空间被用完，如果 / 分区特别大就请忽略这篇文章。

因此需要将一些软件的数据存储到空间大的分区，与 / 分区分开。不仅 Docker 需要这样处理，如 mysql/postgresql 等软件也需要这样处理。" />
<meta property="og:type" content="article" />
<meta property="og:url" content="https://jouyouyun.github.io/post/docker-image-storage/" />
<meta property="article:published_time" content="2019-04-21T12:58:00&#43;08:00"/>
<meta property="article:modified_time" content="2019-04-21T13:46:19&#43;08:00"/>

<meta itemprop="name" content="更改 Docker 数据的存储目录">
<meta itemprop="description" content="Docker 安装后默认将数据存储在 /var/lib/docker 下，随着 image 和 container 的增多，会导致 / 分区的空间被用完，如果 / 分区特别大就请忽略这篇文章。

因此需要将一些软件的数据存储到空间大的分区，与 / 分区分开。不仅 Docker 需要这样处理，如 mysql/postgresql 等软件也需要这样处理。">


<meta itemprop="datePublished" content="2019-04-21T12:58:00&#43;08:00" />
<meta itemprop="dateModified" content="2019-04-21T13:46:19&#43;08:00" />
<meta itemprop="wordCount" content="425">



<meta itemprop="keywords" content="docker,storage," />
<meta name="twitter:card" content="summary"/>
<meta name="twitter:title" content="更改 Docker 数据的存储目录"/>
<meta name="twitter:description" content="Docker 安装后默认将数据存储在 /var/lib/docker 下，随着 image 和 container 的增多，会导致 / 分区的空间被用完，如果 / 分区特别大就请忽略这篇文章。

因此需要将一些软件的数据存储到空间大的分区，与 / 分区分开。不仅 Docker 需要这样处理，如 mysql/postgresql 等软件也需要这样处理。"/>

<!--[if lte IE 9]>
  <script src="https://cdnjs.cloudflare.com/ajax/libs/classlist/1.1.20170427/classList.min.js"></script>
<![endif]-->

<!--[if lt IE 9]>
  <script src="https://cdn.jsdelivr.net/npm/html5shiv@3.7.3/dist/html5shiv.min.js"></script>
  <script src="https://cdn.jsdelivr.net/npm/respond.js@1.4.2/dest/respond.min.js"></script>
<![endif]-->

</head>
<body>
  <div id="mobile-navbar" class="mobile-navbar">
  <div class="mobile-header-logo">
    <a href="/" class="logo">jouyouyun</a>
  </div>
  <div class="mobile-navbar-icon">
    <span></span>
    <span></span>
    <span></span>
  </div>
</div>
<nav id="mobile-menu" class="mobile-menu slideout-menu">
  <ul class="mobile-menu-list">
    <a href="/post/">
        <li class="mobile-menu-item">Archives</li>
      </a><a href="/tags/">
        <li class="mobile-menu-item">Tags</li>
      </a><a href="/categories/">
        <li class="mobile-menu-item">Categories</li>
      </a>
  </ul>
</nav>
  <div class="container" id="mobile-panel">
    <header id="header" class="header">
        <div class="logo-wrapper">
  <a href="/" class="logo">jouyouyun</a>
</div>

<nav class="site-navbar">
  <ul id="menu" class="menu">
    <li class="menu-item">
        <a class="menu-item-link" href="/post/">Archives</a>
      </li><li class="menu-item">
        <a class="menu-item-link" href="/tags/">Tags</a>
      </li><li class="menu-item">
        <a class="menu-item-link" href="/categories/">Categories</a>
      </li>
  </ul>
</nav>
    </header>

    <main id="main" class="main">
      <div class="content-wrapper">
        <div id="content" class="content">
          <article class="post">
    
    <header class="post-header">
      <h1 class="post-title">更改 Docker 数据的存储目录</h1>

      <div class="post-meta">
        <span class="post-time"> 2019-04-21 </span>
        <div class="post-category">
            <a href="/categories/blog/"> BLOG </a>
            </div>
        
      </div>
    </header>

    <div class="post-toc" id="post-toc">
  <h2 class="post-toc-title">文章目录</h2>
  <div class="post-toc-content always-active">
    <nav id="TableOfContents">
<ul>
<li>
<ul>
<li><a href="#处理方案">处理方案</a>
<ul>
<li><a href="#将-var-单独分区">将 <code>/var</code> 单独分区</a></li>
<li><a href="#重新绑定-docker-的数据目录">重新绑定 <code>Docker</code> 的数据目录</a></li>
</ul></li>
</ul></li>
</ul>
</nav>
  </div>
</div>
    <div class="post-content">
      <p><code>Docker</code> 安装后默认将数据存储在 <code>/var/lib/docker</code> 下，随着 <code>image</code> 和 <code>container</code> 的增多，会导致 <code>/</code> 分区的空间被用完，如果 <code>/</code> 分区特别大就请忽略这篇文章。</p>

<p>因此需要将一些软件的数据存储到空间大的分区，与 <code>/</code> 分区分开。不仅 <code>Docker</code> 需要这样处理，如 <code>mysql/postgresql</code> 等软件也需要这样处理。</p>

<h2 id="处理方案">处理方案</h2>

<h3 id="将-var-单独分区">将 <code>/var</code> 单独分区</h3>

<p>配置分区时为 <code>/var</code> 单独分区，然后在挂载到 <code>/</code> 上(在 <code>/etc/fstab</code> 中配置)，这样就可以简单的解决上面的问题了。</p>

<h3 id="重新绑定-docker-的数据目录">重新绑定 <code>Docker</code> 的数据目录</h3>

<p>这个是在数据分区新建一个目录， 如 <code>/Data/var/docker</code> ，然后将 <code>/var/lib/docker</code> 绑定或软链到这个目录，实现将数据从 <code>/</code> 分区中转移出来。</p>

<p>至于数据分区则是一个空间较大的分区，主要用来存放用户数据的。如我喜欢单独分出一个很大的区，将其挂载到 <code>/Data</code> 上，
然后将 <code>$HOME</code> 目录中的 <code>Downloads, Documents, Public, Pictures</code> 等目录都软链到 <code>/Data/DE</code> 下，这样每次重装系统时只需保证 <code>/Data</code> 分区不被格式化就能保证数据不丢失了。</p>

<p>软链的方式就不做描述了，下面给出绑定 <code>/var/lib/docker</code> 到 <code>/Data/var/docker</code> 的步骤：</p>

<ol>
<li><p>创建目标目录</p>

<p><code>mkdir -p /Data/var/</code></p></li>

<li><p>转移数据</p>
<div class="highlight"><div class="chroma">
<table class="lntable"><tr><td class="lntd">
<pre class="chroma"><code class="language-shell" data-lang="shell"><span class="lnt">1
</span><span class="lnt">2
</span><span class="lnt">3
</span><span class="lnt">4
</span></code></pre></td>
<td class="lntd">
<pre class="chroma"><code class="language-shell" data-lang="shell">sudo systemctl stop docker.service
sudo rsync -avPHSX /var/lib/docker /Data/var/ <span class="c1"># -H 处理Hardlink为Hardlink, 必须加上</span>
sudo rm -rf /var/lib/docker
sudo mkdir /var/lib/docker</code></pre></td></tr></table>
</div>
</div></li>

<li><p>目录绑定</p>

<p>添加 <code>/Data/var/docker /var/lib/docker none bind 0 0</code> 到 <code>/etc/fstab</code> 中</p></li>
</ol>
    </div>

    <div class="post-copyright">
  <p class="copyright-item">
    <span class="item-title">文章作者</span>
    <span class="item-content">jouyouyun</span>
  </p>
  <p class="copyright-item">
    <span class="item-title">上次更新</span>
    <span class="item-content">2019-04-21</span>
  </p>
  
  
</div><div class="post-reward">
  <input type="checkbox" name="reward" id="reward" hidden />
  <label class="reward-button" for="reward">赞赏支持</label>
  <div class="qr-code">
    
    <label class="qr-code-image" for="reward">
        <img class="image" src="/images/reward/wechat-qr-code.png">
        <span>微信打赏</span>
      </label>
    <label class="qr-code-image" for="reward">
        <img class="image" src="/images/reward/alipay-qr-code.png">
        <span>支付宝打赏</span>
      </label>
  </div>
</div><footer class="post-footer">
      <div class="post-tags">
          <a href="/tags/docker/">docker</a>
          <a href="/tags/storage/">storage</a>
          </div>
      <nav class="post-nav">
        
        <a class="next" href="/post/influxdb-introduction/">
            <span class="next-text nav-default">InfluxDB 简介</span>
            <span class="next-text nav-mobile">下一篇</span>
            <i class="iconfont icon-right"></i>
          </a>
      </nav>
    </footer>
  </article>
        </div>
        

      </div>
    </main>

    <footer id="footer" class="footer">
      <div class="social-links">
      <a href="mailto:jouyouwen717@gmail.com" class="iconfont icon-email" title="email"></a>
      <a href="https://twitter.com/jouyouyun" class="iconfont icon-twitter" title="twitter"></a>
      <a href="https://github.com/jouyouyun" class="iconfont icon-github" title="github"></a>
  <a href="https://jouyouyun.github.io/index.xml" type="application/rss+xml" class="iconfont icon-rss" title="rss"></a>
</div>

<div class="copyright">
  <span class="power-by">
    由 <a class="hexo-link" href="https://gohugo.io">Hugo</a> 强力驱动
  </span>
  <span class="division">|</span>
  <span class="theme-info">
    主题 - 
    <a class="theme-link" href="https://github.com/olOwOlo/hugo-theme-even">Even</a>
  </span>

  

  <span class="copyright-year">
    &copy; 
    2014 - 
    2019
    <span class="heart">
      <i class="iconfont icon-heart"></i>
    </span>
    <span class="author">jouyouyun</span>
  </span>
</div>
    </footer>

    <div class="back-to-top" id="back-to-top">
      <i class="iconfont icon-up"></i>
    </div>
  </div>
  
  <script src="https://cdn.jsdelivr.net/npm/jquery@3.2.1/dist/jquery.min.js" integrity="sha256-hwg4gsxgFZhOsEEamdOYGBf13FyQuiTwlAQgxVSNgt4=" crossorigin="anonymous"></script>
  <script src="https://cdn.jsdelivr.net/npm/slideout@1.0.1/dist/slideout.min.js" integrity="sha256-t+zJ/g8/KXIJMjSVQdnibt4dlaDxc9zXr/9oNPeWqdg=" crossorigin="anonymous"></script>
  <script src="https://cdn.jsdelivr.net/npm/@fancyapps/fancybox@3.1.20/dist/jquery.fancybox.min.js" integrity="sha256-XVLffZaxoWfGUEbdzuLi7pwaUJv1cecsQJQqGLe7axY=" crossorigin="anonymous"></script>
<script type="text/javascript" src="/dist/even.ece58db6.min.js"></script>








</body>
</html>
